草庐IT

javascript - Node.js:捕获 `child_process.spawn` 的 STDOUT

全部标签

ruby - 如何在 ruby​​ 中进行命名捕获

我想命名从扫描中获取的字符串捕获。怎么做?"555-333-7777".scan(/(\d{3})-(\d{3})-(\d{4})/).flatten#=>["555","333","7777"]有没有可能变成这样{:area=>"555",:city=>"333",:local=>"7777"}或[["555","area"],[...]]我试过了"555-333-7777".scan(/((?)\d{3})-(\d{3})-(\d{4})/).flatten但它返回[] 最佳答案 您应该对命名捕获使用match,而不是scanm

ruby - 从 Ruby 运行命令显示和捕获输出

是否有某种方法可以从Ruby运行(shell)命令显示并捕获输出?也许在一些gem的帮助下?我所说的显示的意思不是在最后打印它,而是在它出现时打印出来,这样用户就可以在运行缓慢的命令时得到反馈。 最佳答案 你可以像这样运行系统调用:`sleep--help`或者像这样system"sleep--help"或者%x{sleep--help}如果是system,它将打印输出并返回true或nil,其他两种方法将返回输出附言哦。它是关于实时显示。所以。你可以使用这样的东西:system("ruby","-e100.times{|i|pi;

ruby - 在 ruby​​ 异常中捕获行号

考虑以下ruby​​代码测试.rb:beginputsthisFunctionDoesNotExistx=1+1rescueException=>epeend出于调试目的,我希望救援block知道错误发生在该文件的第4行。有干净的方法吗? 最佳答案 pe.backtrace我在没有来源的IRBsession上运行它,但它仍然提供了相关信息。=>["(irb):11:in`foo'","(irb):17:in`irb_binding'","/usr/lib64/ruby/1.8/irb/workspace.rb:52:in`irb_b

ruby - 在 Ruby 中捕获异常后重新引发(相同的异常)

我正在尝试通过捕获异常来提高我的Ruby技能。我想知道当您有多个方法调用时重新引发相同类型的异常是否很常见。那么,下面的代码有意义吗?是否可以重新引发相同类型的异常,还是我不应该在process方法中捕获它?classLogodefprocessbegin@processed_logo=LogoProcessor::create_image(self.src)rescueCustomExceptionraiseCustomExceptionendendendmoduleLogoProcessordefself.create_imageraiseCustomExceptionifsome

Ruby:捕获异常后继续循环

基本上,我想做这样的事情(用Python或类似的命令式语言):foriinxrange(1,5):try:do_something_that_might_raise_exceptions(i)except:continue#continuetheloopati=i+1我如何在Ruby中执行此操作?我知道有redo和retry关键字,但它们似乎重新执行“try”block,而不是继续循环:foriin1..5begindo_something_that_might_raise_exceptions(i)rescueretry#do_something_*again,withsameien

ruby - 为什么 "compass watch"说它无法加载 sass/script/node (LoadError)?

我的compasswatch命令有问题-直到几天前它都运行良好。我没有对我的配置文件进行任何更改。我重新安装了Compass,使用rvm更新了Ruby。我检查了我的custom_require.rb文件,但我真的不知道要查找什么。它似乎正在尝试从某处加载文件“sass/script/node”http://sass-lang.com/docs/yardoc/Sass/Script/Node.html我收集了文件路径-但我什么都没有。/Users/sampurcell/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygem

ruby - 一些 JS 运行后,如何让 Capybara 检查可见性?

加载页面后,我有代码运行并根据xhr返回的数据隐藏和显示各种项目。我的集成测试看起来像这样:it"shouldnotshowtheblah"dopage.find('#blah').visible?.shouldbe_trueend当我手动转到此测试运行的上下文中的页面时,#blah不如我所料可见。我怀疑Capybara正在查看页面的初始状态(在本例中是不可见的),评估DOM的状态并在JS运行之前测试失败。是的,我在包含的describeblock上设置了:js=>true:)任何想法将不胜感激!我希望我不必在这里故意延迟,这感觉不稳定并且会减慢速度。 最佳

ruby - 在 Ruby 中连续读取外部进程的 STDOUT

我想通过ruby​​脚本从命令行运行blender,然后它将逐行处理blender给出的输出以更新GUI中的进度条。Blender是我需要读取其标准输出的外部进程并不重要。当blender进程仍在运行时,我似乎无法捕捉到blender通常打印到shell的进度消息,我已经尝试了几种方法。我似乎总是在blender退出后访问blender的标准输出,而不是在它仍在运行时。这是一个失败尝试的例子。它确实获取并打印了blender输出的前25行,但仅在blender进程退出后:blender=nilt=Thread.newdoblender=open"|blender-bmball.blen

ruby - Ruby 中 $stdout 和 STDOUT 的区别

在Ruby中,$stdout(前面有一个美元符号)和STDOUT(全部大写)有什么区别?在进行输出重定向时,应该使用哪个,为什么?$stderr和STDERR也是如此。编辑:刚找到一个relatedquestion. 最佳答案 $stdout是代表当前标准输出的全局变量。STDOUT是代表标准输出的常量,通常是$stdout的默认值。由于STDOUT是常量,您不应该重新定义它,但是,您可以重新定义$stdout而不会出现错误/警告(重新定义STDOUT将发出警告)。例如,您可以:$stdout=STDERR同样适用于$stderr和

ruby - 我怎样才能将 ruby​​ logger 日志输出到 stdout 和文件?

有点像记录器中的T恤功能。 最佳答案 您可以编写一个伪IO类来写入多个IO对象。像这样的东西:classMultiIOdefinitialize(*targets)@targets=targetsenddefwrite(*args)@targets.each{|t|t.write(*args)}enddefclose@targets.each(&:close)endend然后将其设置为您的日志文件:log_file=File.open("log/debug.log","a")Logger.newMultiIO.new(STDOUT,